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In the Claims: 

Please amend claims 3-6 and 8 to read as follows: 

3. (Amended) Method according to claim 1 , wherein the receiver obtains the 
software module to be transferred by combining the object received with the class or group of 
classes retrieved from its database or received, wherein the receiver transmits a message 
"transfer succeeded" or "transfer not succeeded" depending on whether or not the receiver 
succeeds in combining the object and class or group of classes. 

4. (Amended) Method according to claim 1 , wherein the receiver stores each 
class and group of classes with the corresponding class identifier received in its database for later 
use. 

5. (Amended) Method according to claim 1, wherein a sender further combines 
the length of the data file of the class or group of classes with the given name and the result of 
the hash function to provide the class identifier. 

6. (Amended) Method according to claim 1, wherein the receiver checks a class 
or group of classes received from a sender by comparing the result of the hash function of the 
received class identifier with the result obtained by carrying out the same cryptographic hash 
function on the data file of the class or group of classes received. 

8. (Amended) Method according to claim 1, wherein senders and receivers are 
computers in a computer network. 

Please add new claims 10-26 as follows: 

— 10. (New) Method according to claim 2, wherein the receiver obtains the software 
module to be transferred by combining the object received with the class or group of classes 
retrieved from its database or received, wherein the receiver transmits a message "transfer 
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succeeded" or "transfer not succeeded" depending on whether or not the receiver succeeds in 
combining the object and class or group of classes. 

11. (New) Method according to claim 2, wherein the receiver stores each class and 
group of classes with the corresponding class identifier received in its database for later use. 

12. (New) Method according to claim 3, wherein the receiver stores each class and 
group of classes with the corresponding class identifier received in its database for later use. 

13. (New) Method according to claim 2, wherein a sender further combines the length of 
the data file of the class or group of classes with the given name and the result of the hash 
function to provide the class identifier. 

14. (New) Method according to claim 3, wherein a sender further combines the length 
of the data file of the class or group of classes with the given name and the result of the hash 
function to provide the class identifier. 

15. (New) Method according to claim 4, wherein a sender further combines the length 
of the data file of the class or group of classes with the given name and the result of the hash 
function to provide the class identifier. 

16. (New) Method according to claim 2, wherein the receiver checks a class or group of 
classes received from a sender by comparing the result of the hash function of the received class 
identifier with the result obtained by carrying out the same cryptographic hash function on the 
data file of the class or group of classes received. 

17. (New) Method according to claim 3, wherein the receiver checks a class or group of 
classes received from a sender by comparing the result of the hash function of the received class 
identifier with the result obtained by carrying out the same cryptographic hash function on the 
data file of the class or group of classes received. 
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1 8. (New) Method according to claim 4, wherein the receiver checks a class or group of 
classes received from a sender by comparing the result of the hash function of the received class 
identifier with the result obtained by carrying out the same cryptographic hash function on the 
data file of the class or group of classes received. 

19. (New) Method according to claim 5, wherein the receiver checks a class or group of 
classes received from a sender by comparing the result of the hash function of the received class 
identifier with the result obtained by carrying out the same cryptographic hash function on the 
data file of the class or group of classes received. 

20. (New) Method according to claim 2, wherein senders and receivers are computers in 
a computer network. 

21. (New) Method according to claim 3, wherein senders and receivers are computers in 
a computer network. 

22. (New) Method according to claim 4, wherein senders and receivers are computers 
in a computer network. 

23. (New) Method according to claim 5, wherein senders and receivers are computers in 

a computer network. 

24. (New) Method according to claim 6, wherein senders and receivers are computers in 
a computer network. 

25. (New) Method according to claim 7, wherein senders and receivers are computers in 
a computer network. 

26. (New) Method according to claim 8, wherein the computer network is the 
Internet. — 
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Remarks 



Claims 1-9 filed on October 25, 2001, and annexed to the International Preliminary 
Examination Report for the above-identified application are currently pending and form the basis 
for this First Preliminary Amendment. 

Claims 2-6 and 8 have been amended. Claims 10-26 have been added. Claims 1-26 are 
pending for examination as a result of entry of this First Preliminary Amendment. 

This preliminary amendment has eliminated multiple dependent claims without prejudice 
to resubmission and has corrected some minor typographical errors in the claims. Favorable 
consideration and entry of the amendment is requested. 



KNOBLE & YOSHIDA LLC 
Eight Perm Center, Suite 1350 
1628 John F. Kennedy Blvd. 
Philadelphia, PA 19103 
Telephone: (2 1 5) 599-0600 
Facsimile: (215) 599-0601 
e-mail: ki dunleavv@patentwise.com 



Respectfully submitted, 



Dated: April 4, 2002 
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Marked-up Version of the Claims 

In The Claims 

Please amend claims 3-6 and 8 to read as follows: 

3. (Amended) Method according to claim 1 [or 2], wherein the receiver obtains 
the software module to be transferred by combining the object received with the class or group of 
classes retrieved from its database or received, wherein the receiver transmits a message 
'"transfer succeeded" or "transfer not succeeded" depending on whether or not the receiver 
succeeds in combining the object and class or group of classes. 

4. (Amended) Method according to [any one of the preceding claims] claim 1 , 
wherein the receiver stores each class and group of classes with the corresponding class identifier 
received in its database for later use. [graphic hash function on the data file of the class or group 
of classes.] 

5. (Amended) Method according to [any one of the preceding claims] claim 1 , 
wherein a sender further combines the length of the data file of the class or group of classes with 
the given name and the result of the hash function to provide the class identifier. 

6. (Amended) Method according to [any one of the preceding claims] claim 1 , 

wherein the receiver checks a class or group of classes received from a sender by comparing the 

result of the hash function of the received class identifier with the result obtained by carrying out 

the same cryptographic hash function on the data file of the class or group of classes received. 

8. (Amended) Method according to [any one of the preceding claims] claim 1, 
wherein senders and receivers are computers in a computer network[, such as the Internet]. 
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Method for transferring a software module from a sender to a 
receiver in a computer system or network 

The invention relates to a method for transferring a 
software module from a sender to a receiver in a computer sys- 
tem or network, wherein the software module comprises at least 
one object and at least one class, the object being an instance 

of the class (es) . 

In object-oriented software technology it is known to 
build a software module as a combination of so-called objects 
and classes, wherein the or each object that belongs to a 
class, is called an instance of the class. The objects gener- 
ally contain only particular values for the variables specific 
to a predetermined software module, wherein the variables and 
methods to be carried out by the software module are defined in 
the class or classes. 

With increasing use of computer systems and networks, 
such as the Internet, there is an increasing transfer of soft- 
ware modules of the object-oriented type between processes exe- 
cuted within one computer system of between computers of a com- 
puter network. This increasing transferring of software modules 
results in an increase of data traffic within the computer sys- 
tem of computer network. 

A first object of the present invention is to provide 
a method of the above-mentioned type, wherein the data traffic 
within a computer system or computer network during transfer- 
ring a software module is reduced. 

It is a further object of the invention to provide a 
method of this type, wherein a software module can be trans- 
ferred in a secure manner. 

According to the invention a method of the above- 
mentioned type is provided, wherein each class or group of 
classes is provided with a class identifier, wherein both the 
sender and receiver comprises a database of classes and groups 
of classes with corresponding class identifiers, wherein the 
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1 . Declaration and Power of Attorney for Erwin Joost Bolwidt; 

2. Copy of the Notification of Missing Requirements. . . 
. 3 . Check in thf amount of $65 .00. 

A check in the amount of $65.00 is enclosed for the surcharge for the late filing of the 
Declaration and Power of Attorney. Applicant is entitled to claim small entity status . 
The Commissioner is authorized to charge any additional fees associated with this 
response or credit any overpayment, to Deposit Account No. 50-0462. 
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Method fo r transferring a softw are module from a sender to a re- 
ceiver in a computer sy s tem or network 

The invention relates to a method for transferring a 
software module from a sender to a receiver in a computer system 
or network, wherein the software module comprises at least one 
object and at least one class, the object being an instance of 
5 the class (es) , wherein each class or group of classes is pro- 
vided with a class identifier, wherein both the sender and 
receiver comprises a database of classes and groups of classes 
with corresponding class identifier, wherein the sender trans- 
mits the class identifier of a software module to be transferred 

10 to the receiver and the receiver checks its database for pres- 
ence of the received class identifier, and wherein the sender 
transfers only the object of the software module or both the ob- 
ject and class or group of classes depending on the presence or 
absence of the class or group of classes at the receivermethod 

15 for transferring a software module from a sender to a receiver 
in a computer system or network, wherein the software module 
comprises at least one object and at least one class, the object 
being an instance of the class (es) . 

In object-oriented software technology it is known to 

20 build a software module as a combination of so-called objects 

and classes, wherein the or each object that belongs to a class, 
is called an instance of the class. The objects generally con- 
tain only particular values for the variables specific to a 
predetermined software module, wherein the variables and methods 

25 to be carried out by the software module are defined in the 
class or classes. 

With increasing use of computer systems and networks, 
such as the Internet, there is an increasing transfer of soft- 
ware modules of the object-oriented type between processes 

3 0 executed within one computer system or between computers of a 

computer network. This increasing transferring of software mod- 
ules results in an increase of data traffic within the computer 
system or computer network. 



1 AMENDED SHEET 25-10-2001 ; 



Printed:09-1i-200i 




2 



IBM, CRYSTALITZ, GENERAL MAGIC, GMD FOCUS, * Mobile 



Agent Facility Specification' , OMG TC Document., 2 June 1997, 
discloses a common conceptual model for differing mobile agent 
systems. To implement the transfer of classes, the class must be 



the destination agent system. One possible approach is the 
transfer of a list of the names of all possible classes with the 
agent creation or transfer request. The destination agent system 
requests only the classes on that list that it has not cached. 
10 The agent is transferred in serialised form, which is able to 
identify and verify the classes. Agent authent icators are used 
to provide a secure communications infrastructure. However, an 
attacker can monitor communications traffic that transports 
agents and decodes their state data. To counter this attack an 
15 agent may demand confidentiality services as a condition for 

transport. This increases the data traffic within the network. 

A first object of the present invention is to provide a 
method of the above-mentioned type, wherein the data traffic 
within a computer system or computer network during transferring 
2 0 a software module is reduced. 

It is a further object of the invention to provide a 
method of this type, wherein a software module can be trans- 
ferred in a secure manner. 

According to the invention a method of the above - 
2 5 mentioned type is provided, characterised in that the receiver 

transmits a message "present" or "absent" to the sender, and the 
sender provides each class or group of classes by combining a 
given name of each class or group of classes of a software mod- 
ule and the result of a cryptographic hash function, wherein 
30 said result is obtained by executing a cryptographic hash func- 
tion on the data file of the class or group of classes. 

In this manner, a method is obtained, wherein data 
traffic during transferring software modules is significantly 
reduced as the classes or groups of classes need not to be 
35 transferred in all transfers of software modules, and a secure 
identifier is obtained, wherein errors due to identical identi- 
fiers for different classes or groups of classes are excluded. 
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According to a preferred embodiment, the receiver 
checks a classes or group of classes received from a sender by 
comparing the result of the hash unction of the received class 
identifier with the result obtained by carrying out the same 
cryptographic hash function on the data file of the class or 
group of classes received. 

In this manner security in transferring software mod- 
ules is guaranteed as receivers will refuse to use classes where 
the hash function result of the identifier does not match with 
the hash function result obtained by the receiver from the data 
file of the class or the group of classes received. 

The invention will be further explained by reference to 
the drawings in which an embodiment of the method of the inven- 
tion is schematically shown. 
15 Fig. 1 shows in a schematic way a computer network in 

which a method of the invention is implemented. 

Figs. 2 and 3 show flow diagrams of the operation of a 
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sender and a receiver in the method of the invention. 

A preferred embodiment of the method of the invention 
will be described as implemented by way of example in so-called 
software agents which can be used in a computer network, such 
5 as the Internet, for example for searching information on the 
Internet. However, it will be understood that the method of the 
invention is not restricted to this specific application. The 
method can be applied for transferring any software module of 
an object-oriented type as described. 

10 Fig. 1 shows in a very schematic way the Internet com- 

prising a number of interconnected computers or servers 1 and 
computers 2 of users. A user computer 2 can be connected to the 
Internet through a server 1 of an Internet service provider. If 
a user wishes to obtain information on a specific subject from 

15 the Internet, he can send a software agent with his request on 
the Internet to obtain this information. Finding adequate in- 
formation on the Internet is a problem in view of the huge 
amount of information available on the Internet. Existing tech- 
nology such as search engines store the most relevant informa- 

20 tion from the complete Internet to find this information in a 
quick manner if a user requests such information. Existing 
search engines show the disadvantage that searching the com- 
plete Internet from one location is time consuming so that such 
a search will not be carried out frequently and thereby the in- 

25 formation stored by the search engine is dated fast. Moreover, 
existing search engines use their own criteria which do not 
necessarily correspond with the criteria which a user would 
use. A software agent searching the Internet with a request of 
its user may however use its own criteria for finding relevant 

3 0 information and the information can be obtained by communicat- 
ing with other software agents also searching for information. 
During searching the Internet the software agents are trans- 
ferred from one computer 1 to another computer 1 which causes a 
load of the network due to the data traffic involved in such 

3 5 transfers. 

In order to reduce the load of the network caused by 
transferring the software agent, the following method is used. 

It is noted that in the present description the term 
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sender is used to indicate a computer l or 2 from which a soft- 
ware agent is to be transferred to another computer 1 or 2 
which receiving computer is called receiver. It is noted how- 
ever that the present method can also be used to transfer an 
5 agent being present in a directly executable format in a proc- 
ess executed in one computer to another process executed in the 
same computer. In this case the terms sender and receiver refer 
to such processes between which a software agent is trans- 
ferred. It is further noted that in an application of the 

10 method in a computer network, such as the Internet, it is not 

necessary that all computers of the network are adapted or pro- 
grammed to operate as sender and/or receiver. 

Each software agent is made as a software module of an 
object-oriented type. This means within the present description 

15 that the software module comprises one or more objects and one 
or more classes, wherein the objects are instances of the class 
or classes. An object comprises data, such as variable values. 
A class comprises definitions of the data structure, i.e. name 
and type of data fields, and definitions of functions or rou- 

20 tines which are carried out on the objects of the class. Ob- 
jects or more particular the variable values of the objects of- 
ten change due to the execution of the routines which are de- 
fined in the class. If a software module comprises two or more 
classes these classes will be indicated as a group of classes 

25 in this specification. 

According to the method described, a software module 
is transferred from a first computer 1, the sender, to a second 
computer 1, the receiver, in the computer network, by transfer- 
ring the class or classes of the software module only if the 

30 class or classes are not present at the receiver side. In those 
computers of the network adapted to function as a sender and/or 
receiver a database is provided for storing classes or groups 
of classes, wherein a unique class identifier is added to each 
class or group of classes. When a sender wishes to transfer a 

3 5 software module to a receiver, the sender and receiver start to 
communicate to check or whether or not the classes or group of 
classes of the software module to be transferred is present in 
the receiver. The steps of the method are schematically shown 
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in figs. 2 and 3 for the sender and receiver sides, respec- 
tively. 

To start the transfer protocol, the sender transmits a 
start message to the receiver indicating "hereinafter follow 
5 all data of a software module" . All objects which are part of 
the software module to be transferred are combined in a data 
file and this data file is transmitted to the receiver. Fur- 
ther, the sender transmits the unique class identifier to the 
receiver. Thereafter, the receiver checks its database for the 

10 presence of the unique class identifier received. The receiver 
transmits a return message "present" or "absent" to the sender 
and the sender transmits a data file with the class or group of 
classes only if a message "absent" was received. If Java is 
used as software language for the software module, the data 

15 files of the classes of one software module can be bundled into 
one data file by means of a Java tool JAR. The thus obtained 
data file is a so-called jar-file. Generally in the present 
method a class will contain a software routine or the like. 
Other embodiments could involve using classes containing refer- 

20 ence to routines or the like and not the routine itself. 

The receiver obtains the software module by combining 
the objects received from the sender with the class or group of 
classes either retrieved from its database or received from the 
sender. If the receiver succeeds in combining the objects and 

25 class or group of classes, the receiver transmits a message 

"transfer succeeded" to the sender. If the receiver cannot com- 
bine the objects and classes, a message "transfer not suc- 
ceeded" will be transmitted to the sender. 

In this manner data traffic in the network will be 

3 0 significantly reduced as generally it will only be necessary to 
transfer the objects of a software module. 

Of course, at any transfer of a class or group of 
classes, a receiver receiving new classes can store the class 
or group of classes together with the corresponding unique 

35 class identifier in its database for future use. In this manner 
the database will gradually be further completed reducing fu- 
ture data traffic. 

It is noted that although in the above -described exam- 
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pie, the objects and class identifier are transmitted from the 
sender to the receiver without interruption, its is also possi- 
ble to transmit first the class identifier to check its pres- 
ence at the receiver and thereafter the objects. However, the 
5 order described shows the advantage that the number of switch- 
ings from transmitting to receiving at the sender and receiver 
sides is reduced resulting in a further reduction of the time 
period for transferring a software module as switching in a 
computer network is relatively time consuming. 

10 In the method of the invention the unique class iden- 

tifier is preferably obtained in the following manner. First 
the user may give a predetermined name to a class or group of 
classes. This given name is a first part of the class identi- 
fier. Further, all classes of a software module are bundled 

15 into one data file which is the data file to be transferred if 
the group of classes is absent at the receiver side. At the 
sender side a program is executed determining a cryptographic 
hash function of the data file of the group of classes and the 
result of this hash function is stored. This hash function re- 

2 0 suit is the second part of the unique class identifier. 

It is noted that any cryptographic hash function can 
be used which provides a result which is significantly shorter 
than the original data file, wherein a small change in the 
original data file provides a large change in the hash function 
25 result and wherein it is very difficult to determine an input 
data file leading to a predetermined hash function result. 

As a further option to provide a unique class identi- 
fier, it is possible to add the length of the data file as a 
third part to the unique class identifier. 

3 0 In this manner it is guaranteed that if a sender 

transmits the unique class identifier of a software module to a 
receiver and the receiver indicates that the class or group of 
classes of the unique class identifier received is present in 
its database, indeed the correct class or classes are available 
35 at the receiver side. 

Further, the use of a cryptographic hash function pro- 
vides security to the transfer method. The receiver will always 
check the unique class identifier with the data file of classes 
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received. To this end the receiver will execute the same cryp- 
tographic hash function on the data file of the classes and 
will compare the result of its own hash function with the hash 
function result in the class identifier. If a match is not 
5- found, the receiver will transmit a message "transfer not suc- 
ceeded" to the sender and will terminate the transfer protocol. 

The method described can be used advantageously in an 
Internet application of software agents, wherein the software 
agent travels on the Internet to search information and the 

10 like. However, it will be understood that the method results in 
the same advantages of reducing data traffic between processes 
running in one computer system or the transfer of software mod- 
ules between computers in any type of network. 

The invention is not restricted to the above described 

15 embodiment and can be varied in a number of ways within the 
scope of the following claims. 




8 y-:\ 
CLAIMS : , 

1. Method for transferring a software module from a 
sender to a receiver in a computer system or network, 
wherein the software module comprises at least one object 
and at least one class, the object being an instance of the 
5 class (es) , wherein each class or group of classes is 

provided with a class identifier, wherein both the sender 
and receiver comprises a database of classes and groups of 
classes with corresponding class identifier, wherein the 
sender transmits the class identifier of a software module 
10 to be transferred to the receiver and the receiver checks 

its database for presence of the received class identifier, 
and wherein the sender transfers only the object of the 
software module or both the object and class or group of 
classes depending on the presence or absence of the class or 
15 group of classes at the receiver, characterised in that the 
receiver transmits a message "present" or "absent" to the 
sender, and the sender provides each class or group of 
classes by combining a given name of each class or group of 
classes of a software module and the result of a 
20 cryptographic hash function, wherein said result is obtained 
by executing a cryptographic hash function on the data file 
of the class or group of classes. 

2. Method according to claim 1, wherein the sender 
transmits first all objects and the class identifier to the 

25 receiver if a message "absent" is received. 

3. Method according to claim 1 or 2 , wherein the 
receiver obtains the software module to be transferred by 
combining the object received with the class or group of 
classes retrieved from its database or received, wherein the 

30 receiver transmits a message "transfer succeeded" or 

"transfer not succeeded" depending on whether or not the 
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receiver succeeds in combining the object and class or group 
of classes. 

4 . Method according to any one of the preceding 
claims, wherein the receiver stores each class and group of 
5 classes with the corresponding class identifier received in 
its database for later use. 



ill 
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graphic hash function on the data file of the class or group of 
classes. • . 

cmv oy\& op fh£ pre,cedimcLa\m$ 

5"-6-. Method according to claim- 5 v wherein a sender fur- 
ther combines the length of the data file of the class or group 
of classes with the given name and the result of the hash func- 
tion to provide the class identifier, any one op hhe prec&clincjcUx 

6^. Method according to c la ir ffl 5 V or & , wherein the re- 
ceiver checks a class or group of classes received from a 
sender by comparing the result of the hash function of the re- 
ceived class identifier with the result obtained by carrying 
out the same cryptographic hash function on the data file of 
the class or group of classes received. 

o 

y -8-. Method according to claim 9-, wherein the receiver 
transmits a message "transfer succeeded" or "transfer not suc- 
ceeded" depending on the comparison of the result of the hash 
function on the data file received and the result of the hash 
function of the class identifier. 

3 -9". Method according to any one of the preceding 
claims, wherein senders and receivers are computers in computer 
network, such as the Internet. 

$ -3rd*. Method according to claim -9-, wherein the software 
module is a so-called agent for searching, exchanging and/or 
providing information on the network. 
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